guint param_id,
GValue *value,
GParamSpec *pspec);
-static GskRenderNode * gtk_frame_get_render_node (GtkWidget *widget,
- GskRenderer *renderer);
+static gboolean gtk_frame_draw (GtkWidget *widget,
+ cairo_t *cr);
static void gtk_frame_size_allocate (GtkWidget *widget,
GtkAllocation *allocation);
static void gtk_frame_remove (GtkContainer *container,
int baseline,
GtkAllocation *out_clip,
gpointer data);
+static gboolean gtk_frame_render (GtkCssGadget *gadget,
+ cairo_t *cr,
+ int x,
+ int y,
+ int width,
+ int height,
+ gpointer data);
G_DEFINE_TYPE_WITH_CODE (GtkFrame, gtk_frame, GTK_TYPE_BIN,
g_object_class_install_properties (gobject_class, LAST_PROP, frame_props);
- widget_class->get_render_node = gtk_frame_get_render_node;
- widget_class->size_allocate = gtk_frame_size_allocate;
+ widget_class->draw = gtk_frame_draw;
+ widget_class->size_allocate = gtk_frame_size_allocate;
widget_class->measure = gtk_frame_measure_;
- widget_class->state_flags_changed = gtk_frame_state_flags_changed;
+ widget_class->state_flags_changed = gtk_frame_state_flags_changed;
container_class->remove = gtk_frame_remove;
container_class->forall = gtk_frame_forall;
GTK_WIDGET (frame),
gtk_frame_measure,
gtk_frame_allocate,
- NULL,
+ gtk_frame_render,
NULL,
NULL,
NULL);
return frame->priv->shadow_type;
}
-static GskRenderNode *
-gtk_frame_get_render_node (GtkWidget *widget,
- GskRenderer *renderer)
+static gboolean
+gtk_frame_draw (GtkWidget *widget,
+ cairo_t *cr)
+{
+ gtk_css_gadget_draw (GTK_FRAME (widget)->priv->gadget, cr);
+
+ return FALSE;
+}
+
+static gboolean
+gtk_frame_render (GtkCssGadget *gadget,
+ cairo_t *cr,
+ int x,
+ int y,
+ int width,
+ int height,
+ gpointer data)
{
- GtkFramePrivate *priv = GTK_FRAME (widget)->priv;
+ GtkWidget *widget;
+ GtkFramePrivate *priv;
+ gint xc, yc, w, h;
GtkAllocation allocation;
- GskRenderNode *node;
- cairo_t *cr;
- int xc, yc, w, h;
- gtk_widget_get_allocation (widget, &allocation);
+ widget = gtk_css_gadget_get_owner (gadget);
+ priv = GTK_FRAME (widget)->priv;
- node = gtk_css_gadget_get_render_node (priv->gadget, renderer, FALSE);
+ cairo_save (cr);
- cr = gsk_render_node_get_draw_context (node, renderer);
+ gtk_widget_get_allocation (widget, &allocation);
/* We want to use the standard gadget drawing for the border,
* so we clip out the label allocation in order to get the
* frame gap.
*/
xc = priv->label_allocation.x - allocation.x;
- yc = allocation.y;
+ yc = y;
w = priv->label_allocation.width;
h = priv->label_allocation.height;
gtk_css_gadget_draw (priv->border_gadget, cr);
- cairo_destroy (cr);
+ cairo_restore (cr);
- gtk_container_propagate_render_node (GTK_CONTAINER (widget), renderer, node);
+ GTK_WIDGET_CLASS (gtk_frame_parent_class)->draw (widget, cr);
- return node;
+ return FALSE;
}
static void